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Postsecondary Data Partnership (PDP). This technical 
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the development of both term cohort files and course 
files. The process utilized course and cohort file templates 
provided by National Student Clearinghouse, query 
extractions developed by the Empower representative, 
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processing by the Achieving the Dream (ATD) data 
coach, utilizing SAS software which is useful for processing 
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employed by NICC during the initial PDP data collection 
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the PDP. This brief can be used as an approach for data 


preparation for the PDP data collection process. 
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SUMMARY 
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The Clearinghouse Postsecondary Data Partnership 
data collection requires two types of files. The first type 
of file is a single-record student cohort file that consists 
o) el Malo\Vaielel— aime] mial—m lacie lieame)miat-m(-saamel—liale 
reported. The second type of file is a multiple-record 
course file that consists of student’s course records for 
the term being reported. 
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such as Cohort Term, Cohort Year, and Student ID. To 
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When the course files are prepared, the cohort files are 
merged with the course files by Student ID. 


The process accomplishes two objectives: 1) creates and 
saves the cohort files for uploading to the Clearinghouse, 
and for future processing and 2) creates the course files 
that are uploaded to the Clearinghouse and includes the 
cohort students enrolled during the term being reported. 


TECHNICAL 
DETAILS bata ri 


PREPARATION AND SUBMISSION 


Nebraska Indian Community College worked with the Empower vendor, 
utilizing the Clearinghouse file documentation and sample templates, to 
write queries for both the cohort and course file extracts for each term, 

fall, spring, and summer, fall 2012-summer 2019. The files were saved in CSV 
format and shared with the ATD data coach to prepare for file submission 
to the Clearinghouse. The cohort files included new students in each 

term being reported. The registrar at the institution manually completed 
the template with the required data fields that were missing. To begin 
processing in SAS, the analyst imported the cohort files into the SAS 
environment and scanned for missing data fields. Data fields that were not 
populated in the institution’s files were subsequently coded using the SAS 
software. The cohort files were processed using appropriate field formatting 
and prepared for uploading to the Clearinghouse. The cohort files were 
saved for future processing of the course files. 


The initial course file extracts were handled similarly by importing the 
course files into the SAS environment and scanning for missing data fields. 
Likewise, SAS software was utilized to code data fields that were missing 
in the institution’s course files. One challenge with the course file was 

it included all students enrolled during the term. To create a file that 
included cohort students, all of the cohort files to date, were merged 
with the term’s course file to create a final course file for the term. Since 
the cohort files included the initial identifying information of cohort term, 
cohort year, and student ID, this information was incorporated into the 
course file and the results captured all cohorts’ information for the term. 


Data Extractions 


e To facilitate the preparation of cohort and course files, the Clearinghouse 
provides documentation for file formatting and field length requirements. 
Additionally, the Clearinghouse provides sample templates that can be 
downloaded and used as a reference in preparation of the data files. 
Nebraska Indian Community College worked with the Empower vendor, 
utilizing the file documentation and sample templates, to write queries 
for both the cohort and course file extracts for each term, fall, spring, and 
summer, fall 2012-summer 2019. The files were saved in CSV format and shared 


with the AID data coach to prepare for file submission to the Clearinghouse. 
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Cohort Files 


The cohort files included new students in each term being reported. 
While the queries were able to capture new students in each term 
being reported, not all of the information was captured in the query 
process. The registrar at the institution completed the template with 
the required data fields by manually adding the missing information. 
In some instances, the registrar looked up the information on the 
individual student and populated the missing fields. Information that 
could not be located in the student information system was left blank. 
If the information is required by the Clearinghouse, missing information 
will create an error when files are uploaded to the Clearinghouse. File 
preparers will need to adhere to field requirements and ensure that 
required fields are provided for each student in the file. 


To begin a subsequent data quality check, the ATD Data Coach imported 
the cohort files into the SAS environment and scanned for missing data 
fields. Data fields that were not populated in the institution’s files were 
subsequently coded using SAS software. The process required collaboration 
with the registrar to ensure that the fields were accurately coded. The 
cohort files were processed in the SAS environment using appropriate field 
formatting and prepared for uploading to the Clearinghouse. The cohort 
files were saved for future processing of the course files. 


Course Files 


The course files included new students in each term being reported. 
While the queries were able to capture all students in each term 
being reported, not all of the information was captured in the query 
process. The registrar at the institution completed the template with 
the required data fields by manually adding the missing information. 
In some instances, the registrar looked up the information on the 
individual student and populated the missing fields. Information that 
could not be located in the student information system was left blank. 
If the information is required by the Clearinghouse, missing information 
will create an error when files are uploaded to the Clearinghouse. File 
preparers will need to adhere fo field requirements and ensure that 
required fields are provided for each student in the file. This also ensures 
that the PDP reports will provide quality reports that enhance student 
success efforts locally and across the network. 


e The initial course file extracts were handled similarly by importing the 
course files into the SAS environment and scanning for missing data 
fields. Likewise, SAS software was utilized to code data fields that were 
missing in the institution’s course files. The course file is the ‘meat’ of 
the longitudinal reporting function of the PDP data and hence includes 
course grades information, term grade point averages, course Cip 
Codes, credit hours attempted and completed during the term, etc. Gee 
documentation for a complete listing). The main distinction of the course 
file from the cohort file is that information is associated with the course(s) 
with which students are enrolled, and multiple instances of student 
records are provided. 


e Course grades are typically stored in a student information system utilizing 
numerical values or letter grades. The PDP utilizes numerical coding for 
grading systems on a 4.0 scale. At NICC, SAS software was utilized to 
translate the letter grades into the appropriate numerical coding. The 
registrar provided documentation from the institution which provided the 
letter grade translations. 


Challenges during file creations 


e One challenge with the initial course file extract was it included alll 
students enrolled during the term. To create a file that included cohort 
students, all of the cohort files to date, were merged with the term’s 
course file to create a final course file for the term. Since the cohort files 
included the initial identifying information of cohort term, cohort year, 
and student id, this information was incorporated into the course file and 
the results captured all cohorts’ information for the reported term. 


e The cohort selection process at NICC utilized queries that select students 
from the student information system that met new student criteria. In 
a few instances, students were selected for more than one cohort. A 
quality check was added to the course file creation process to identify 
duplicate records. 
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RESULTS 


AND CONCLUSIONS 


The results of utilizing the data collection process outline 
here demonstrated an efficient process for handling 

the PDP data collections. Cohorts of students were 
reported in the first term of enrollment and also included 
in subsequent course data collections if enrolled during 


the reporting term. 


Students were reported in the cohort files in a single record instance along 
with identifying information. The identifying information was stored in a 
cohort dataset and used for subsequent course data collections. Students 
were reported once in a cohort file which equipped the Clearinghouse 
research center with compiling the institution’s new student enrollment 
trends and demographics. 


The multi-record course files included all of the student cohorts to date, in 
all courses enrolled during the term. Since course files include the reporting 
term and term outcomes, the files facilitate longitudinal cohort tracking 
and metrics measured at points-in-time along the student’s journey. 


The PDP data files will be compiled and reported to NICC in early spring 
2020 in two ways: tableau dashboards and an analysis ready file. Utilizing 
queries in the Empower system and populating the cohort and course 
templates, Nebraska Indian CC prepared the historical data collections for 
the PDP in the fall of 2019. The ATD data coach subsequently processed 
the files in the SAS environment. The institution will gain access to tableau 
dashboards including cohort enrollment trends, early momentum mefrics, 
student outcomes including completion and transfer, for all of the cohorts 
submitted during the data collection. 


By participating in the Clearinghouse data collections on an on-going 
basis, NICC will be able to determine the impacts of process, policy, and 
procedural changes that emerge from utilizing the Tableau dashboards 
to improve student experiences at the institution. Data partners and the 
institution also have access to the analysis ready file for future processing 
and fo aid in identifying additional student success improvements. 


Recommendations 


e The initial cohort file can be saved for future use and creates a record 
for each student that is utilized in subsequent course files. 


e The multiple record course file adheres to reporting information that 
is associated with the course(s) with which students are enrolled, 
with some exceptions. For example, term grade point averages are 
associated with the student and captured at the end of the term. 
Additionally, the cohort identifying information is associated with 
the student and/or the term being reported. Pay careful attention 
to the field requirements and carefully read the requirements to 
conceptualize the file structure needed. 


e The initial data collection is the most time Consuming including up 
to 7 years of data, but the process outlined in this document can be 
replicated for future data collections. 


e While the process can be replicated for future data collections, 
coding changes in the student information system will need to be 
addressed in the on-going query extracts. Missing data fields are 
often an indication of a change in the location of data stored in 
the student information system. 


e The query process developed at NICC will evolve and improve over 
time as missing data fields are handled in the query. 


e The query process developed at NICC through the assistance of the 
Empower vendor helped to develop a potential vendor solution to 
handling the Clearinghouse PDP data collections and increasing 
participation across the Achieving the Dream (ATD,2020) network of 
colleges, and beyond. 
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APPENDIX A. Entire Cohort 
Program for Sample Institution 


OPTIONS PS=5000 LS=256 NONUMBER NOCENTER; 

%LET PathRoot=F:\ AchievingtheDream\ ATD_XXXX\PDP; /*Change to your path*/ 
LIBNAME Cohort “&PathRoot\CohortFiles”; 

LIBNAME Course “&PathRoot\CourseFiles”; 

LIBNAME ALL “&PathRoot\SASDatasets\00_AllCohorts”; 

LIBNAME PDP “&PathRoot\Uploads”; 


/*Enter Student Clearinghouse Information’*/ 


%LET SBD=20191112; /* Clearinghouse File Completion Date */ 

%LET SC=XXXXXX; /* OPEID# */ 

%LET SA=XXXXXXXX; /*Service Account # for Header Row*/ 

%LET BC=00 /*Branch Code # for Header Row*/ 

%LET ID=XXXxX; /*Institutional Short Name for Header Row’*/ 

%LET SFTPMailbox=XXXXXXXpap; /*PDP Mailbox Address (OPEID, BC,) & pdp*/ 


%LET ytO1=2019SU; /*Academic term using term naming convention*/ 

%LET ChO1=2018-19; /“Academic year*/ 

%LET chtm01=Summer; /*PDP term - Fall, Winter Spring or Summer*/ 

%LET TermBeginDate=20190521; /*Term Begin Date in this format, yyyymmdd*/ 
%LET TermEndDate=20190720; /*Term End Date in this format, yyyymmdad’*/ 


data WORK. test 
%let EFIERR_ =O; /* set the ERROR detection macro variable */ 
infile “&Pathroot\CohortFiles\ &yt0l..csv” delimiter = *,’ 
MISSOVER DSD Irecl=32767 firstobs=2 ; 
informat CHI] $2. ; 
informat Cohort $10. ; 
informat CohortTerm $10. ; 
informat SSN 9. ; 
informat ITIN 9. ; 
informat ID 9. ; 
informat FirstName $60. ; 
informat MiddleName S60. ; 
informat LastName $60. ; 
informat Address] $30. ; 
informat Address2 $30. ; 
informat City $30. ; 
informat State $2. ; 
informat Zip $10. ; 
informat Country $2. ; 
informat Birthdate $8. ; 
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informat Ethnicity $2. ; 
informat Race $2, ; 
informat InstitutionIDType $5. ; 
informat Institution|D $8. ; 
informat HSDip $1. ; 
informat HSDipYr $4. ; 
informat HSGPA 4.2 ; 
informat HSWeightedGPA 4.2 ; 
informat FirstGen $1. ; 
informat Dual $2. ; 
informat EnrollmentType $1. ; 
informat NumberofCreditsAttemptedtTR 6.; 
informat NumberofCreditsAccepted IR 8; 
informat MathPlacement $2. ; 
informat EngPlacement $2. ; 
informat GatewayMath $2. ; 
informat GatewayEnglish $2. ; 
input 
CH1 $ 
Cohort $ 
Cohortterm $ 
SSN 
ITIN 
ID 
FirstName $ 
MiddleName $ 
LastName $ 
Address] $ 
Address2 $ 
City $ 
State $ 
Zip $ 
Country $ 
Birthdate $ 
Ethnicity $ 


Race $ 

InstitutionIDType $ 

InstitutionID $ 

HSDip $ 

HSDipyYr $ 

HSGPA 

HSWeightedGPA 

FirstGen $ 

Dual $ 

EnrollmentType $ 

NumberofCreditsAttemptedTr 
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NumberofCreditsAcceptedTR 
MathPlacement $ 
EngPlacement $ 
GatewayMath $ 
GatewayEnglish $ 


if ERROR_ then call symputxC_EFIERR_’,1); /* set ERROR detection macro variable */ 


CohortTerm="&chtm01"; 
TermBegin="&lermBeginDate”; 
TermEnd="&lermEndDate’; 
Cohort="&ch01"; 

if Addressl=" * then Address1="UK’; 
if Address2=’ * then Address2=" °; 
if City=" * then City="UK’; 

if State=’ * then State="UK’; 

if FirstGen=’ * then FirstGen='N’; 

IF Ethnicity = C *) THEN Ethnicity="UK’; 
If Ethnicity = ‘H’ then Race=UK’; 
InstitutionIDType="OPEID’; 

format InstitutionID $8.; 
InstitutionID=cats (&SC","&BC"); 
CH1='D1’; 


run; 
/*Final Processing*/ 


Data Final&yt01 all .cohort_&yt01; 
set test; 

ITIN=" *; 

SSN=" *; 

run; 


data test; 
set /*input sas file*/ 
final&ytOl end=lsLast ; 
file “&pathroot\Uploads\’&SFTPMailbox’_cohort&yt01&SC .txt” dsd dim=","; 
If [N_=1 then do; 
put 
@1 “DCEO1,&SA,&SC,&BC.,,,,&SBD,,&ID,,,,” 


put 
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“CH1,Cohort,Cohort Term, Cohort Term Begin Date, Cohort Term End Date, 

SSN, ITIN,Student ID,First Name,Middle Name, 

Last Name-Street Line 1,Street Line 2,City, 

State,Zip/Postal Code,Country,Date of Birth, Ethnicity,Race,Institution ID Type. Institution ID,HS 
Completion Status, 

HS Completion Year,HS Unweighted GPA, 

HS Weighted GPA, First Gen,Dual and Summer Enrollment,Enrollment Type, 

Number of College Credits Attempted to Transfer,Number of College Transfer Credits Accepted, 
Math Placement,English Placement,Gateway Math Status,Gateway English Status” 


end; 


put CH1 Cohort CohortTlerm TermBegin TermEnd SSN ITIN ID FirstName MiddleName LastName 
Address] Address2 

City State Zip 

Country Birthdate Ethnicity Race 

Institution|IDType InstitutionID HSDip HSDipYr 

HSGPA HSWeightedGPA FirstGen Dual Enrollmentlype 

NumberofCreditsAttemptedTR NumberofCreditsAcceptedIR 

MathPlacement EngPlacement 

GatewayMath GatewayEnglish 


/*Sample Output Line*/ 


IF IsLast=1 then do; 
CT=_n_+3; 

put @1 “TI” 

@3°, 

@4 CT ** 


end; 
run; 
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APPENDIX B. Entire Course Program for 
sample Institution 


OPTIONS PS=5000 LS=256 NONUMBER NOCENTER;: 
%LET PathRoot=F:\ AchievingtheDream\ ATD_XXXX\PDP; /*“Change to your path’/ 


LIBNAME Cohort “&PathRoot\CohortFiles”; 

LIBNAME Course “&PathRoot\CourseFiles”; 

LIBNAME ALL “&PathRoot\SASDatasets\00_AllCohorts”; 
LIBNAME PDP “&PathRoot\Uploads”; 


/*Enter Student Clearinghouse Information*/ 


%LET SBD=20191112; /* Clearinghouse File Completion Date */ 

%LET SC=XXXXXX; /* OPEID# */ 

%LET SA=XXXXXXXX; /*Service Account # for Header Row’*/ 

%LET BC=00; /*Branch Code # for Header Row’*/ 

%LET ID=XXXX; /*Institutional Short Name for Header Row’*/ 

%LET SFTPMailbox=XXXXXXXpdp; /*PDP Mailbox Address OPEID, BC, & pdp*/ 
%LET yt01=2019SU; /*“Academic term using term naming convention*/ 

%LET chO1=2018-19; /“Academic year’*/ 

%LET chtm01=Summer; /*PDP term - Fall, Winter Spring or Summer*/ 


/*Cohort Terms Reported*/ 


%LET ytl=2013FA; 
%LET yt2=2014SP; 
%LET yt3=2014SU; 
%LET yt4=2014FA; 
%LET yt5=2015SP; 
%LET yt6=2015SU; 
%LET yt7=2015FA; 
%LET yt8=2016SP; 
%LET yt9=2016SU; 
%LET ytlO=2016FA; 
%LET ytl1=2017SP; 
%LET yt12=2017SU; 
%LET yt13=2017FA; 
%LET ytl4=2018SP; 
%LET yt15=2018SU; 
%LET ytl6=2018FA; 
%LET yt17=2019SP; 
%LET yt18=2019SU; 
%LET yt19=2019FA; 
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data WORK.Course 

%LET _EFIERR_ = 0; /* set the ERROR detection macro variable */ 

infile “&Pathroot\CourseFiles\ &yt0l course.csv” delimiter = *,/ MISSOVER DSD |recl=32767 firstobs=2 ; 
informat CHI] $2. ; 
informat Cohort $7. ; 
informat Cohort_Term $10. ; 
informat Academic_Year $7. ; 
informat Term $10. ; 
informat Institution_ID_Type $5. ; 
informat Institution_ID best32. ; 
informat SSN best82. ; 
informat ITIN $9. ; 
informat ID 20. ; 
informat FirstName $60. ; 
informat MiddleName S60. ; 
informat LastName $60. ; 
informat ADCStuNameSuffix $10. ; 
informat Address] $30. ; 
informat Address2 $30. ; 
informat City $20. ; 
informat State $2. ; 
informat Zip $10. ; 
informat Country $2. ; 
informat Birthdate $20. ; 
informat ADCStuPersonalPhone $20. ; 
informat Pell $2. ; 
informat ADCStuEmailAddress $255. ; 
informat CompleteDevMath $4. ; 
informat CompleteDevEnglish $4. ; 
informat Intent $4. ; 
informat Degreelype $2. ; 
informat SemesterGPA best32. ; 
informat CummulativeGPA best32. ; 
informat CoursePrefix $50. ; 
informat CourseNumber $20. ; 
informat CourseSection $20. ; 
informat CourseName $50. ; 
informat ADCclsShortTitle $255. ; 
informat CourseCIP $10. ; 
informat Courselype $2. ; 
informat MathOrEnglishGateway $10. ; 
informat CorequisiteCourse $1. ; 
informat CourseBeginDate $20. ; 
informat CourseEndDate $20. ; 
informat LetterGrade $20. ; 
informat NumCreditsAttempt best32. ; 
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informat NumCreditsComplete best32. ; 
informat Method $1. ; 

informat Core_Course $1. ; 

informat Core_Course_Type $1. ; 

informat Core_Competency_Completed $1. ; 
informat Total_Combined_Earned___Transf $1. ; 
informat Puroose_of_Course_Exchange best32. ; 
informat Certification_Endorsed_Curricu $1. ; 
informat Certificate_Endorsing_Industry $1. ; 
informat Grade_Effective_Date $1. ; 

informat DGI_Institutional_ID_Type best82. ; 
informat DGI_Institutional_ID best32. ; 

informat DGI_Student_ID $1. ; 


input 
CHI $ 
Cohort $ 
Cohort_Term $ 
Academic_Year $ 
Term $ 
Institution_ID_Type $ 
Institution_|ID 
SSN 
ITIN $ 
ID 
FirstName $ 
MiddleName $ 
LastName $ 
ADCStuNamesuffix $ 
Address] $ 
Adadress2 $ 
City $ 
State $ 
Zip 
Country $ 
Birthdate 
ADCStuPersonalPhone $ 
Pell $ 
ADCStuEmailAddress $ 
CompleteDevMath $ 
CompleteDevEnglish $ 
Intent $ 
Degreelype $ 
SemesterGPA 
CummulativeGPA 
CoursePrefix $ 
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CourseNumber 

CourseSection $ 

CourseName $ 

ADCClsShortiitle $ 

CourseCIP 

Courselype $ 
MathOrEnglishGateway $ 
CorequisiteCourse $ 
CourseBeginDate 
CourseEndDate 

LetterGrade $ 
NumCreditsAttempt 
NumCreditsComplete 

Method $ 

Core_Course $ 
Core_Course_Type $ 
Core_Competency_Completed $ 
Total_Combined_Earned___Transf $ 
Purpose_of_Course_Exchange 
Certification_Endorsed_Curricu $ 
Certificate_Endorsing_Industry $ 
Grade_Effective_Date $ 
DGIl_Institutional_ID_Type 
DGI_Institutional_ID 
DGI_Student_ID $ 


if ERROR_ then call symputxC_EFIERR_‘’,1); /* set ERROR detection macro variable */ 


BeginYear=substr(CourseBeginDate,7,2); 
BeginMonth=substr(CourseBeginDate, 1,2); 
BeginDay=substr(CourseBeginDate,4,2); 
CourseBeginDate=cats(‘20",beginyear,beginmonth,beginday); 
EndYear=substr(CourseEndDate,/,2); 
EndMonth=substr(CourseEndDate, 1,2); 
EndDay=substr(CourseEndDate,4,2); 
CourseEndDate=cats(20”,Endyear,Endmonth,Endday); 
BirthYear=substr(BirthDate, 7,2); 

BirthMonth=subsitr(BirthDate, 1,2); 
BirthDay=substr(BirthDate,4,2); 

if BirthYear <= substrC &yt01",3,2) then 

BirthDate=cats (20’,birthyear,birthmonth,birthday); 

else BirthDate=cats (19, birthyear,birthmonth, birthday); 
Course=cats(CoursePrefix, CourseNumben; 

if substr(Course,1,4) in CMTH1’) or substr(course,1,5) in CMATH1’) 
then MathorEnglishGateway='M’; 

else if sulostr(Course,1,4) in CENG1’) or substr(course,1,5)iN CENGLI’) then 
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MathorEnglishGateway='E’; 
else MathorEnglishGateway='NA’; 


lf NumCreditsAttempt < NumCreditsComplete then do; 


NumCreditsAttempt=NumCreditsComplete; 
end; 


lf LetterGrade='A’ then grade="4.00'; 

else if LetterGrade=A~’ then grade="3.67’; 

else if LetterGrade='B+’ then grade="3.33’; 

else if LetterGrade='B’ then grade="3.00’; 

else if LetterGrade='B-’ then grade="2.67'; 

else if LetterGrade='C+’ then grade='2.33’; 

else if LetterGrade='C’ then grade='2.00’; 

else if LetterGrade='C-’ then grade="1.67’; 

else if LetterGrade='D’ then grade='1.00’; 

else if LetterGrade='F’ then grade="F’; 

else if LetterGrade in CP’) then Grade=’P’; 

else if LetterGrade in CR’) then Grade=0'; 

else if LetterGrade=‘Audit’ then Grade='A’; 
else if LetterGrade in CW“,/UW’) then Grade='W’; 
else if LetterGrade=UF’ then Grade="F’; 

else if substr(LetterGrade,1,1)='Il' then Grade="1’; 
else if LetterGrade=’ * then Grade="M’; 

else Grade='0’; 


If Country="UN‘ then do; 
Country="US’; 

end; 

run; 


proc sort; by id; 
run; 


/*Combine Cohorts Reported to Date*/ 
%macro cohort; 


proc sort data=All .Cohort_&yt out=cohort&yt (keep=id cohort cohortterm) ; by id; 


run; 

%mend; 

%LET yt=&ytl; %cohort; 
%LET yt=&yt2; %cohort; 
%LET yt=&ytl; %cohort; 
%LET yt=&yt2; %cohort; 
%LET yt=&yt3; %cohort; 
%LET yt=&yt4; %cohort; 
%LET yt=&yt5; %cohort; 
%LET yt=&yt6; %cohort; 
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%LET yt=&yt7; %cohort; 
%LET yt=&yt8; %cohort; 
%LET yt=&yt9; %cohort; 
%LET yt=&ytlO; %cohort; 
%LET yt=&ytl1; %cohort; 
%LET yt=&ytl2; %cohort; 
%LET yt=&yt13; %cohort; 
%LET yt=&ytl4; %cohort; 
%LET yt=&yt15; %cohort; 
%LET yt=&yt16; %cohort; 
%LET yt=&ytl7; %cohort; 
%LET yt=&yt18; %cohort; 
/*%LET yt=&ytl9; %cohort; 
%LET yt=&yt20; %cohort; 
%LET yt=&yt21; %cohort; 
%LET yt=&yt22; %cohort; 
%LET yt=&yt23; %cohort; 
%LET yt=&yt24; %cohort;*/ 


/*Facilitates the Coding Change, to Cohort Term from Numeric to Fall, Winter, Spring, Summer, in 
September 2019*/ 
Data allcohorts&yt01; 
format CohortTerm $10.; 
set cohort&yt] 
cohort&yt2 
cohort&yt3 
cohort&yt4 
cohort&yt5 
cohort&yt6 
cohort&yt7 
cohort&yt8 
cohort&yt9 
cohort&ytl0 
cohort&ytll 
cohort&yt12 
cohort&yt13 
cohort&ytl4 
cohort&yt15 
cohort&ytl6 
cohort&ytl7 
cohort&yt18 
/*cohort&ytl9 
cohort&yt20 
cohort&yt2]1 
cohort&yt22 
cohort&yt23 


cohort&yt24*/ 
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if CohortTerm=‘1’ then CohortTlerm= Fall’; 
if CohortTerm="3' then CohortTerm='Spring’; 
if CohortTerm="6' then Cohortlerm=‘Summer’; 


proc sort; by id; 
run; 

/*“Code Developmental Requirements*/ 
Data DEVGroup&yt01; 
set All .Cohort_&ytl 
All .Cohort_&yt2 
All .Cohort_&yt3 
All .Cohort_&yt4 
All .Cohort_&yt5 
All .Cohort_&yt6 
All .Cohort_&yt7 
All .Cohort_&yt8 
All .Cohort_&yt9 
All .Cohort_&yt10 
All .Cohort_&yt11 
All .Cohort_&ytl2 
All .Cohort_&yt13 
All .Cohort_&ytl4 
All .Cohort_&yt15 
All .Cohort_&ytl6 
All .Cohort_&yt17 
All .Cohort_&yt18& 


proc sort data=DEVGroup&yt01; by id; 
run; 


/*Begin Processing Developmental Completions*/ 
Data Course2; 

merge course (in=a) devgroup&ytOl(in=b keep=id MathPlacement EngPlacement ); by id:; 
format completedevmath $2. completedevenglish $2.; 
completedevmath=’ °; 

completedevenglish=’ °; 

if a; 

if mathplacement="N’ then do; 
CompleteDevMath='D’; 

If course in CMTH99",,MATH904’) and grade in (P’) 
then CompleteDevMath='C’; 

end; 

if mathplacement="C’ then do; 
CompleteDevMath=’NA’; 

end; 
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if engplacement='N’ then do; 
CompleteDevEnglish='D’; 

If course in CENG99", ‘“ENGL900") and grade in ('P’) 
then CompleteDevEnglish=’C’; 

end; 

if engplacement="C’ then do; 
CompleteDevEnglish='NA’; 

end; 

run; 


Data devmath (keep=id completedevmath) deveng (keep=id completedevenglish); 
set course2; 
run; 


proc sort data=devmath; by completedevmath; 
proc sort data=devmath nodupkey; by id; 

proc sort data=deveng; by completedevenglish; 
proc sort data=deveng nodupkey; by id; 

run; 


Data CombDev; 
merge deveng devmath; by id; 
run; 


/*Finish Creating Student Completion Attribute*/ 

Data course3; 

merge course2 (in=a) Combdev ; by id; 

if a; 

if CompleteDevEnglish=" * then CompleteDevEnglish=’NA’; 
if CompleteDevMath=’ * then CompleteDevMath='NA’; 
run; 


/*Final Merge*/ 

Data final&yt01; 

format DGllInstitution|ID $8. InstitutionID $8. TotalCombCredits 10. CoreCourselype $20. 
GradeEffectiveDate $8. DGIStudentiD $20.; 

merge allcohorts&ytO1 (in=a) Ccourse3 (in=b drop=Cohort Cohort_term term); by id; 
ifa and b; 

AcademicYear="&ch01"; 

Term="&chtm01”"; 

SectionID='Missing’; 

SSN=’ °; 

ITIN=" *; 

CH1='D1’; 

CoreCourse="’ °; 

CoreCourselype=" °; 
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CoreCompetencyCompleted=" * 
PurposeCourseExchange=z2; 
CertCurriculumProgram=" *; 
CertEndorsinglndustry=" *; 
GradeEffectiveDate=" *; 
CourseDescription=" °; 
TotalCombCredits=.; 
InstitutionIDType="OPEID’; 
InstitutionID=catsC&SC","&BC"); 


DGllnstitution|IDType="OPEID’; 
DGllnstitutionID=cats(*&SC","&BC”); 

DGI|StudentID=ID; 

Semestergoa3=put(semestergpa,4.2); 

if SemesterGPA3=. then SemesterGPA2="Missing’; 

else SemesterGPA2=SemesterGPA3; 
Cummulativegoa3=put(Ccummulativegpa,4.2); 

if CummulativeGPA3=. then CummulativeGPA2='Missing’; 
else CummulativeGPA2=CummulativeGPA3; 

RUN; 


/*Export to Text File*/ 


data test2; 

set /*input sas file*/ 

Final&yt0l end=lsLast ; 

file “&pathroot\Uploads\’&SFTPMailbox’_course&yt01&SC txt” DSD dim=","; 
lf N_=1 then do; 

put 


put 

“CH1,Cohort,Cohort Term,Academic Year,Term,|nstitution ID Type,|nstitution ID, 

SSN.ITIN. Student ID,First Name,Middle Name, 

Last Name,Suffix, Current Street 1,Current Street 2,Current City, 

Current State,Current Zip/Postal Code,Current Country,Date of Birth, 

Student Phone Number,Pell Recipient,Student 

Email, CompleteDevMath,CompleteDevEnglish, Transferlntent, 

Degree Type Sought,Semester/Session GPA,Overall GPA,Course Prefix, Course Number,Section 
ID,Course Name,Course Description,Course CIP, 

Course Type,MathOrEnglishGateway,Co-requisite Course,Course Begin Date, 

Course End Date,Grade,Number of Credits Attempted,Number of Credits Earned,Delivery Method, 
Core Course,Core Course Type,Core Competency Completed,Total Combined Earned and 
Transferred Credits, 

Purpose of Course Exchange,Certification Endorsed Curriculum/Program,Certificate Endorsing Industry, 
Grade Effective Date,DGI Institution ID Tyoe,DGI Institution ID, DGI Student ID” 
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end; 


put CH1 Cohort CohortTerm AcademicYear Term Institution|Dlype InstitutionID 

SSN ITIN ID FirstName MiddleName 

LastName ADCStuNamesuffix Address] Address2 City 

State Zip Country Birthdate 

ADCStuPersonalPhone Pell ADCStuEmailAddress CompleteDevMath CompleteDevEnglish Intent 
Degreelype SemesterGPA2 CummulativeGPA2 CoursePrefix CourseNumber SectionID CourseName 
ADCClsShortTitle CourseCIP 

Courselype MathorEnglishGateway CorequisiteCourse CourseBeginDate 

CourseEndDate Grade NumCreditsAttempt NumCreditsComplete Method 

CoreCourse CoreCourselype CoreCompetencyCompleted TotalCombCredits 
PurposeCourseExchange CertCurriculumProgram CertEndorsingindustry 

GradeEffectiveDate DGllnstitutionIDType DGllnstitutionID DGIStudentID 


/*Sample Output Line*/ 


IF IsLast=1 then do; 
CT=_n_+3; 

put @1 “TI” 

@3 */ 

@4 CT ** 


end; 
run; 
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